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SPECIFICATION 

To All Whom It May Concern: 

Be it known that We, Hideki MURAYAMA, Hiroshi YASHIRO, 
Satoshi YOSHIZAWA, Kazuo HORIKAWA, Takehisa HAYASHI , Hiroshi 
IWAMOTO and Kimitoshi YAMADA have invented new and useful 
improvements in : 

A COMPUTER SYSTEM HAVING A 
PLURALITY OF COMPUTERS EACH CONTROLLING ACCESS 
TO SHARED MEMORY BASED ON STRUCTURAL DEFINITION INFORMATION 
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A COMPUTER SYSTEM HAVING A 
PLURALITY OF COMPUTERS EACH CONTROLLING ACCESS 
TO SHARED MEMORY BASED ON STRUCTURAL DEFINITION INFORMATION 

BACKGROUND OF THE INVENTION 

The present invention relates to a computer system 
having a plurality of computer systems connected to each other. 
More particularly, the present invention relates to a computer 
system having a plurality of computers connected to each other , 
wherein each computer controls access to a shared memory based 
on structural definition information which describes a 
structure of the computer system and wherein the computer 
system may be a loosely-coupled computer system. 

Loosely-coupled computer systems which share hard 
disks so as to share data have been proposed. In order to 
implement such systems a plurality of hard disk controllers and 
an attachment for connecting hard disks to be shared are 
required. 

Examples of apparatus for implementing hard disk 
sharing by SCSI Profile of Fibre Channel is described in The 
VAXcluster Concept: An Overview of a Distributed System; by 
Nancy P. Kronenberg et. al., Digital Technical Journal, No. 5 
September 1987, pp 7-21, and examples of apparatus for 
implementing Fibre Channel Small Computer System Interface 
(SCSI) Profile which has been standardized in ANSI, is 
described in Implementing a Fibre Channel SCSI Transport, by 
Robert Snively, IEEE COMPCON, Spring 1994, pp 78-82 have been 
proposed • 

Examples of apparatus implementing a Network File 




System (NFS) is described in DISTRIBUTED SYSTEMS, by George F. 
Coulouris et. al. , pp 391-407, 1991 as a means for realizing 
file sharing by Remote Procedure Call (RPC) in a 
loosely-coupled computer system has also been proposed • 
5 In Fibre Channel, when the shared hard disks are 

accessed, access is required to be conducted through the 
attachment. Thus, the increased access to the attachment 
causes the reduction of performance, the performance reduction 
is a serous disadvantage. 
10 A System is a system which uses other processors for 

performing processing operations based upon the request of 
^3 another processor. RPC provides for communications between 

H processors to cause other processors to execute processing for 

another processor. Thus, soft overhead increases. Increased 
fi.15 soft overhead causes a reduction in the performance of the 
o system. The reduced performance is a disadvantage. 

;;;; summary of the invention 

It is the object of the present invention to provide 
20 a computer system in which a processor directly controls shared 
hard disks through an attachment so as to provide high 
performance hard disk sharing, wherein the computer system may 
be a loosely-coupled computer system. 

Another object of the present invention is to provide 
25 a loosely-coupled computer system having a plurality of 
computers connected to each other, wherein each computer 
controls access to a shared memory based on structural 
definition information which describes a structure of the 
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computer system, wherein the computer system may be a loosely- 
coupled computer system. 

The present invention provides a computer system 
having a plurality of computers connected to each other, 
5 wherein each of the computers is connected to a shared memory 
device. Each computer includes a controller for controlling 
access from the computer to the shared memory device connected 
to the computer and permitting access to the shared memory 
device from another computer in response to a processing 

10 requirement from the other computer. The controller in each 

* ' computer permits access to the shared memory device based on 

structural definition information which describes a structure 
^ of the computer system. The computer system may be a loosely- 
coupled computer system. 

lp£ Further, the present invention provides a computer 

2 system, which is structured so that a processor required for 
hard disk access controls directly the hard disk. The 
processor is also provided with a requirement judging section 
for judging a hard disk processing requirement from another 

20 ~~ processor, a hard disk requirement processing section for 
processing the processing requirement, and a remote disk 
controlling section for transferring as required the processed 
requirement between the processor connected to the hard disk 
and an attachment for remote access by the other computer. 

25 

BRIEF DESCRIPTION OF THE DRAWINGS 

The present invention will be more apparent from the 
following detailed description, when taken in conjunction with 



3 




the accompanying drawings, in which: 

Fig. 1 is a block diagram of the first embodiment of 
a loosely-coupled computer system structure; 

Fig. 2 is a block diagram of the second embodiment of 
5 a loosely-coupled computer system structure; 

Fig. 3 is a conceptual diagram of an example fcf 
structural definition information; 

Fig. 4 is a conceptual diagram of an example of disk 
processing requirement command; 
10 Fig. 5 is a conceptual diagram of an example of disk 

^ processing status; 

?4 Fig. 6 is a conceptual diagram of an example of 

f'* computer coupling mechanism adapter packet; 

m3 Fig. 7 is a conceptual diagram of an example of 

Ws remote disk processing requirement command; 

Q Fig. 8 is a conceptual diagram of an example of 

H remote disk processing status; 

*X Fig. 9 is a conceptual diagram of an example of 

actual disk processing requirement command; 
20 Fig. 10 is a conceptual diagram of an example of 

actual disk processing status; 

Fig. 11 is an operation flow chart of the disk 
requirement processing section; 

Fig. 12 is a flow chart of the non-remote requirement 
25 processing; 

Fig. 13 is a flow chart of the remote requirement 
processing; 

Fig. 14 is a flow chart of the remote requirement 
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actual disk processing; 

Fig. 15 is a block diagram of the disk control 
mechanism sharing control section; 

Fig. 16 is a flow chart of the remote requirement 
refusing processing. 

DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS 

The present invention will be described referring to 
the drawings. 

A first embodiment of a computer system of the 
present invention is shown in Fig. 1. The computer system 
illustrated in Fig. 1 may be a loosely-coupled computer system 
which is structured from computers 100-1 to 100-N coupled to 
each other by a computer coupling mechanism 140 (N is a natural 
number hereinafter) . Each of the computers 100-1 to 100-N 
comprises a processor 101, memory 102 , I/O device 103, disk 
control mechanism 104, computer coupling network adapter 13 0, 
and disk requirement processing section 110, which are 
connected to a system bus 105, and a disk 106-1 to 106-N 
connected to a disk control mechanism 104. The processor 101 
comprises, for example, a CPU. The memory comprises, for 
example, a RAM. The I/O device 103 is a device for input and 
output, and comprises a secondary memory associated with, for 
example, a display, keyboard, and hard disk. The I/O device 

103 may not necessarily be contained as an element of a 

computer 100-1 to 100-N in a case where communication 
processing by the computer coupling network adapter 130 
executes the input-output function. 




The disk control mechanism 104 is a mechanism for 
controlling the disk 106-1 to 106-N responding to a processing 
requirement from the disk requirement processing section 110, 
and, for example, comprises logic such as TTL and CMOS. The 
5 disks 106-1 to 106-N each comprises a secondary memory such as 
a hard disk. 

The computer coupling network adapter 13 0 is a device 
for coupling computers 100-1 to 100 -N and the computer coupling 
mechanism 140 to each other and performing 
10 transmitting-receiving processing of data in responding to an 

indication from the processor 101 and disk requirement 
\y processing section 110, and, for example, logic such as TTL and 
M CMOS. The computer coupling mechanism 140 is a coupling 
[v% network for coupling the computers 100-1 to 100-N to 
15 communicate to each other. The computer coupling mechanism 
% h 140, for example, comprises logic such as TTL and CMOS. The 

r; computer coupling mechanism can also take the form of a network 
or any other type of connection or coupling apparatus such as a 
^ bus, a switch or plural switches, an exchange or switching 
20 system for example an Asynchronous Transfer Mode (ATM) 

switching system. The computer coupling mechanism can also be 
a Small Computer System Interface (SCSI) . A SCSI can also be 
used to connect the disk control mechanism 104 to the disk 106- 
1 to 106-N. 

25 The disk requirement processing section- 110- performs 

communication between the disk requirement processing sections 
110 through the computer adapter 105 and computer coupling 
mechanism 140 as required and responds to a processing 
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requirement from the processor 101 to the corresponding disk 
control mechanism 104. The disk requirement processing section 
110 responds to the processing requirement instead of the disk 
control mechanism 104. Thus, the processor 101 can control the 
access to the disk 106-1 to 106-N in the same access control 
procedure. The disks from 106-1 to 106-N can be shared only 
when sharing is needed, therefore, the computer coupling 
mechanism 140 will not impact on the performance of the 
computer . 

Next, details of a disk requirement section 110 are 
described. A disk requirement processing section 110 receives 
two types of processing requirements, namely a processing 
requirement from the processor 101 in the same computer and a 
remote processing requirement from the other computers from 
100-1 to 100 -N connected through the computer coupling 
mechanism 140. The disk requirement processing section 110 
performs two types of control processing operations, namely 
control of the disk control mechanism 104 in the same computer 
and issue of remote control requirement to other computers from 
100-1 to 100-N connected through the computer coupling 
mechanism 140. The disk requirement processing section 110 
comprises a requirement control section 111, requirement 
acceptance judging section 112, required designee judging 
section 113, structural definition information holding section 
114 , disk control mechanism sharing control -section 115, and 
remote disk control section 120, which components are connected 
to the internal bus 116. 

The requirement control section 111 receives a 
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processing requirement from the processor 101 in the same 
computer requiring processing of the disk control mechanism 104 
and a remote processing requirement from other computers 
connected through the computer coupling mechanism 140 and 
5 performs the requested processing requirements. The 

requirement control section 111, for example, comprises' logic 
such as TTL and CMOS. 

The requirement acceptance judging section 112 judges 
acceptance of the processing requirement received by the disk 

10 requirement processing section 110 based on the structural 
definition information stored in the structural definition 
information holding section 114. The requirement acceptance 

& judging section 112 , for example, comprises logic such as TTL 

and CMOS. 

315 The required designee judging section 113 judges to 

determine which of a computer and disk are to be assigned to 
perform the processing requirement received by the disk 
requirement processing section 110 based on the structural 
definition information stored in the structural definition 

20 information holding section 114. The received designee judging 
section 113, for example, comprises logic such as TTL and CMOS. 

The structural definition information holding section 
114 stores structural definition information which describes a 
structure of the computer system. Particularly, the structural 

25 definition information is used to determine whether the sender 
of the processing requirement has access right to the 
corresponding disk, and whether a predetermined password has 
been provided for improvement of security. 



8 



The disk control mechanism sharing control section 
115 performs an adjustment between two types of processing 
requirements, namely a processing requirement from the 
processor 101 in the same computer to the disk control 
5 mechanism 104 and remote processing requirement from the other 
computers connected through the computer coupling mechanism 
140. The disk control mechanism and, for example, comprises 
logic such as TTL and CMOS. 

The remote disk control section 120 controls the disk 
10 control mechanism 104 in response to a remote processing 

requirement from one of the other computers connected through 
the computer coupling mechanism 140 and issues remote control 
f ,ils requirements to the computers connected through the computer 
coupling mechanism 140. 
IS! The remote disk control section 120 comprises a 

Q remote requirement processing section 121, a remote requirement 
jU issue section 122, and a computer coupling mechanism adapter 
In control section 123 , which are connected to the internal bus 
124. 

20 The remote requirement processing section 121 

performs processing of a remote processing requirement from the 
other computers connected through the computer coupling 
mechanism 140. The remote requirement processing section 121, 
for example, comprises logic such as TTL and CMOS. The remote 

25 requirement issue section. 122 issues remote control 

requirements to other computers connected through the computer 
coupling mechanism 140 . The remote requirement issue section 
122, for example, comprises a logic such as TTL and CMOS. 

9 

I 



The computer coupling mechanism adapter control 
section 123 controls the computer coupling mechanism adapter 
105 to communicate to other computers connected through the 
computer coupling mechanism 140. The computer coupling 
mechanism adapter control section 123 , for example, comprises 
logic such as TTL and CMOS. 

In Fig. 2, another embodiment of a loosely-coupled 
computer system structure is illustrated. Fig. 2 illustrates 
an example in which three computers and disks connected to each 
computer are shared partially. The computer-1 100-1 has disks 
106-1 , ID = A, B, and C where ID represents identifiers in each 
computer. The disks 106-1, ID = A and B are non-shared disks. 
The disk 106-1, ID = C is a disk shared by the computer-1 100-1 
and the computer-2 100-2. 

The computer-2 100-2 has disks 106-2, ID = A and B. 
The disk 106-2, ID = A is non-shared disk, and the disk 106-2, 
ID = B is a disk shared by the computer-2 100-2 and the 
computer-3 100-3. The computer-3 100-3 has disks 106-3, ID = 
A, B, and C. The disk 106-3, ID = A is non-shared disk, and 
the disks 106-3, ID = B and C are disks shared by the 
computer-1 100-1, computer-2 100-2 and computer-3 100-3. 

Table 1 shows an example of structural definition 
information corresponding to the loosely-coupled computer 
system structure embodiment 2. The structural definition 
information is information for representing structural 
definition such as what computer and disk correspond to the 
processing required to the disk requirement processing section 
110, whether the requirer of the requirement has the access 
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right corresponding to the disk, and password for improving 
security. The information is structured in a form of table. 
The virtual disk is a virtual name of a disk designated by 
processing command issued form the processor 101. In this 
example, total eight disks are contained in the whole 
loosely-coupled computer system, and a disk is designated using 
identifiers from VDISK-1 to VDISK-8. 



Table 1 



Virtual Disk 


Actual Disk 
Control 
Computer 


Corresponding 
Disk in 
Controlled 
Computer 


Access Right 
Information 


Password 


VDISK-1 


Computer- 1 


A 


Computer— 1 


AdL 


VDISK-2 


Computer- 2 


A 


. Computer— 2 




VDISK-3 


Computer- 3 


A 


Computer-3 


CDE 


VDISK-4 


Computer-3 


c 


Computer-1, 
computer-2 , 
computer-3 


DEF 


VDISK-5 


Computer-3 


B 


Computer-1, 
Computer-2 , 
Computer-3 


EFG 


VDISK-6 


Computer-2 


B 


Computer-2 
Computer-3 


FGH 


VDISK-7 


Computer -1 


B 


Computer-1 


GHI 


VDISK-8 


Computer- 1 


C 


Computer-1 
Computer-2 


HIJ 



The actual disk control computer represents a 
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computer from 100-1 to 100-3 to which the disk control 
mechanism 104 for controlling a target disk from 106-1 to 106-3 
of actual issue of processing command. 

The corresponding disk in a control computer 
represents a disk from 106-1 to 106-3 in the actual disk 
control computer corresponding to the virtual disk. This disk 
is referred to as actual disk hereinafter. In this embodiment, 
it is shown that the control computer is contained in a form of 
identifier (ID) for controlling disks. The access right 
information tells that an access from which computer is 
permitted for each virtual disk. In this example, the access 
right information is identifiers (ID) of the computers for 
permitting access. The access right information may be stored 
individually for each processing command such as data reading, 
data writing, and status reading. The password is used to 
improve security. For example, password may be checked for all 
requirements to improve reliability. 

If only a single requirement corresponding to a 
specific process out of a plurality of requirements from a 
computer having the access right should be permitted access, a 
piassword is added to each of the requirements and checked to 
improve s ecur i t y . 

An example of structural definition information 
corresponding to the computer-1 in the loosely-coupled computer 

system structure embodiment 2 is shown. As the structural „ 

definition information, the information which shows the 
correspondence of each computer to the actual disk control 
computer allows the computer to identify the virtual disk which 
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accepts an access without interpolation of the computer 
coupling mechanism. 

Information shown in Table 1 and Fig. 3 is stored in 
the external secondary memory device and it may be set when 
initialization is processed. Otherwise, it is set during 
operation by a utility tool. 

In Fig. 4, an example of a disk processing 
requirement command issued from the processor 101 is* shown. 
400 is a disk requirement command. The virtual disk ID 401 is 
an identifier for designating a disk in the system. The 
password 402 is necessary for password checking as shown in 
Fig. 3. The disk control command/data 403 is a command for 
controlling disks from 106-1 to 106-N, and data necessary for 
executing the command, and it is issued through the disk 
control mechanism 104. 

In Fig. 5, an example of a disk processing status 
which is returned to the processor 101 when disk processing is 
completed. 500 is the disk processing status. The virtual 
disk ID 401 is the same as the virtual disk ID 401 in Fig. 4. 
The password 502 is the same as the password 502 in Fig. 4, 
but, may not be used when returning. The disk status /data is a 
status information and data at the end of the command which is 
returned from the disk from 106-1 to 106-N to the processor 
101. 

In Fig. 6, an example of a computer coupling . 

mechanism adapter packet. The computer coupling mechanism 
performs distribution of packets. The transmission side 
computer ID 601 is an identifier representing a computer of 
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transmission side. The receiving side computer ID 602 is an 
identifier representing a computer of receiving side. The data 
603 are data which is transferred. It is preferable to add 
redundant codes for improvement of reliability on the head or 
5 tail of a packet to improve reliability. It is also preferable 
to symbolize a packet to improve security. 

In Fig. 7, an example of a remote disk processing 
requirement command is shown. 700 is a remote disk processing 
requirement command. The requirer computer ID 701 is an 
10 identif ier ;> which represents a computer requiring processing to 
rii the disk. The actual disk control computer ID 702 is an 

f j f identifier representing a computer which stores the disk 

J - control mechanism 104 controlling directly the computer 

%Q required for processing of the disk. The actual disk ID 703 is 

fills an identifier representing the disk to be processed. The 
C!3 password 402 and disk control command/data 403 are the same 

H command as described in Fig. 4. 

,jl In Fig. 8 f an example of a remote disk processing 

status is shown. 800 is a remote disk processing status. The 

20 requirer computer ID 701 is an identifier representing the 

computer which requires processing of the disk, and it is the 
same command as described in Fig. 7. The actual disk control 
computer ID 702 is an identifier representing the computer 
which has the disk control mechanism 104 for controlling 

25 directly the disk to be processed, and it is the- same command 
as described in Fig. 7. The actual disk ID 703 is an 
identifier representing the disk to be processed, it is the 
same command as described in Fig. 7. The password 502 and disk 
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status/data 503 are the same commands as described in Fig. 5. 

In Fig. 9, an example of actual disk processing 
requirement command is shown. 900 is an actual disk processing 
requirement command. The actual disk ID 703 is an identifier 
representing the disk to be processed, it is the same command 
as described in Fig. 7. The disk control command/data 403 is a 
command for controlling the disk from 106-1 to 106-N and data 
necessary for execution of the command. The actual disk 
processing requirement command is the same command as described 
in Fig. 4. 

In Fig. 10 , an example of an actual disk processing 
status is shown. 1000 is an actual disk processing status. 
The actual disk ID 703 is an identifier representing the disk 
to be processed, and it is the same command as described in 
Fig. 7. The disk status/data 503 is status information at the 
end of a command which is returned to the processor 101 from 
the disk from 106-1 to 106-N and data. It is the same command 
as described in Fig. 5. 

A flow of operation of the disk requirement 
processing section is described referring to Fig. 11. First, 
as shown in the step 1110, a disk processing requirement 
command issued from the processor 101 is received by the 
requirement control section 111 and the flow proceeds to the 
step 1120. 

As shown in the step 1120, the required disk judging 
section 113 judges an actual disk control computer (refer to 
Table 1) corresponding to the virtual disk ID 401 referring to 
the structural definition information (refer to Table 1) stored 
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in the structural definition information holding section 114 , 

and the flow proceeds to step 1130. 

Step 1130 judges whether the actual disk control 

computer corresponding to the virtual disk ID 4 01 is identical 
5 to the processor 101 which issued the disk processing 

requirement command referring to the structural definition 

information (refer to Table 1 and Fig. 3). If the actual disk 

control computer corresponding to the virtual disk ID 401 is 

not identical to the processor 101 which issued the disk 
10 processing^ requirement command, the flow proceeds to the 

branched step 1140 , on the other hand, if the actual disk 
= ;1 control computer corresponding to the virtual disk ID 401 is 
f " identical to the processor 101 which issued the disk processing 

Ji;f requirement command, the flow proceeds to the branched step 1150. 

=15 If the actual disk control computer corresponding to 

the virtual disk ID 401 is not identical to the processor 101 
H which issued the disk processing requirement command, a remote 

requirement processing operation is executed as shown in the 

step 1140. 

20 The remote requirement processing operation is 

described referring to Fig. 13 and Fig. 14. If the actual disk 
control computer corresponding to the virtual disk ID 401 is 
identical to the processor 101 which issued the disk processing 
requirement command, as shown in the step 1150, the requirement 

25 acceptance judging section 112 checks the access right to the 
virtual disk ID 401 to be processed designated by the disk 
processing requirement command 400 referring to access right 
information (refer to Table 1) of the structural definition 



information, and the flow proceeds to the step 1160. The 
access right information represents a computer having access 
right. 

Then, in the case of no access right in the step 
1160, the flow proceeds to the branched step 1195 , and in the 
case of yes access right, the flow proceeds to the branched 
step 1170. 

In the case of no access right, the requirement is 
refused as shown in the step 1195, and the flow ends. In the 
case of ending with a refusal of the requirement, the 
requirement control section 111 creates a disk requirement 
processing status 500 and returns it to the processor 101. The 
disk processing status 500 sets a status code to inform the 
results that the virtual disk ID 401 and password 402 are 
identical to the disk requirement processing command 400 and 
that the disk status has no access right. 

In the case of access right, as shown in the step 
1170, the requirement acceptance judging section 112 performs 
password checking by comparing the password 402 of the disk 
processing command 400 and the password 305 of the structural 
definition information stored in the structural definition 
information holding section 114, the flow proceeds to the step 
1180. Then, in the step 1180, if the passwords are not 
identical, the flow proceeds to the branched step 1195, and if 
the pass words are identical , the flow proceeds to the branched 
step 1190. In this example, the status notice is the same for 
refusals due to no access right and due to mismatch of 
passwords, but it is preferable to differentiate the status 
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notice to improve fault detection function. 

If the passwords are identical, as shown in the step 
1190, the non-remote requirement processing is executed and the 
flow ends. The disk requirement processing operation may be 
5 carried out by software when the processor is provided in the 
disk requirement processing section 110. Non-remote 
requirement processing operation is described referring to Fig. 
12. 

A flow of the non-requirement processing operation is 
10 described Referring to Fig. 12. First, as shown in the step 
r ,, : 1210, the requirement control section 111 prepares an actual 

rl disk processing requirement command 900 from the disk 

requirement command 400. The virtual disk ID 401 of the disk 
Md? processing requirement command 400 is converted to a 
8s corresponding actual disk ID 703 referring to the structural 
Q definition information (refer to Table 1) , thereby, the actual 

H disk processing requirement command 900 is prepared from the 

ijji disk processing requirement command 400. 

Then, as shown in the step 1220, the requirement 
20 control section 111 issues the actual disk processing 

requirement command 900 to the disk control mechanism sharing 

control section 115. 

As shown in the step 1230, the disk control mechanism 

sharing control section 115 serializes the actual disk 
25 processing requirement command 900 issued from the remote 

requirement processing section 121 and requirement control 

section 111, and issues it to the disk control mechanism 104. 

The serializing processing of the actual disk processing 
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requirement command 900 is described in the description of Fig. 
15. 

As shown in the step 1240, the disk control mechanism 
104 controls a disk from 106-1 to 106-N using the actual disk 
processing requirement command 900. Then, as shown in the step 
1250, the disk control mechanism 104 returns an actual disk 
processing status 1000 to the disk control mechanism sharing 
control section 115 as a return value to the control to the 
disk from 106-1 to 106-N by the actual disk processing 
requirement command 900. 

As shown in the step 1260, the disk control mechanism 
sharing control section 115 returns the actual disk processing 
status 1000 to the requirement control section 111. Then, as 
shown in step 1270, the requirement control section 111 
retrieves the virtual disk ID 401 corresponding to the actual 
disk ID 703 of the actual disk processing status 1000 referring 
to the structural definition information (refer to Fig. 3A) , 
thereby the requirement control section 111 creates a disk 
processing status 500. 

As shown in step 1280, the requirement control 
section 111 returns the disk processing status 500 to the 
processor 101, and the non-remote requirement processing ends. 
The non-remote requirement processing operation may be 
performed by software alternatively when the processor is 
incorporated in the disk requirement processing section 110. 

A flow of the remote requirement processing operation 
is described referring to Fig. 13. First, as shown in the step 
1310, the remote requirement issue section 122 creates a remote 
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disk processing requirement command 700 from the disk 
processing requirement command 400 and structural definition 
information. Referring to the structural definition 
information (refer to Table 1) , the virtual disk ID 401 of the 
disk processing requirement command 400 is converted to the 
corresponding actual disk ID 703 , thereby, the actual" disk 
processing requirement command 900 is created from the disk 
processing requirement command 400. Then, as shown in the step 
13 20, the remote requirement issue section 122 requires 
transmission of the remote disk processing requirement command 
700 to the computer coupling adapter control section 123. 

As shown in the step 1330, the computer coupling 
mechanism adapter control section 123 transfers the remote disk 
processing requirement command 700 to the remote requirement 
processing section 121 of the actual disk control computer 
(refer to Table 1) through the computer coupling mechanism 
adapter 130. Then, as shown in the step 1340, the remote 
requirement processing section 121 requests checking of access 
right of the remote disk processing requirement command 700 to 
the requirement acceptance judging section 112. 

As shown in the step 1350, the requirement acceptance 
judging section 112 receives the remote disk processing 
requirement command 700, and checks the access right to the 
actual disk control computer ID 702 and actual disk ID 703 to 
be processed as designated by the remote disk processing 
requirement command 700 by retrieving the access right 
information (refer to Table 1) of the structural definition 
information, and the flow proceeds to the step 1360. Then, as 
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shown in the step 1360, if there is no access right, the flow 
proceeds to the branched step 1395 , and if there is access 
right, the flow proceeds to the branched step 1370. 

When there is no access right, as shown in the step 
5 1395, the requirement is refused, and the flow ends. When the 
requirement is refused and the flow ends, the remote 
requirement processing section 121 creates a remote disk 
processing status 800, and returns it to the remote requirement 
issue section 122 and sends an error notice to the processor 

10 which issued the disk processing requirement command. Details 
r\ of this processing are described in the description of Fig. 16. 
V;\ When there is access right, as shown in the step 

C 1370, the requirement acceptance judging section 112 compares 
the password of 402 of the remote disk processing requirement 

is command 7 00 and the password 3 05 of the structural definition 
information stored in the structural definition information 

? = holding section 114 to check password, and the flow proceeds to 

Mil the step 1380. Then, in the step 1380, if the passwords are 

not identical, the flow proceeds to the branched step 1395. On 

20 the other hand, if the passwords are identical, the flow 
proceeds to the branched step 1390. In this example, the 
status notice is the same for refusals due to no access right 
and due to mismatch of pass words, but it is preferable to 
differentiate the status notice to improve fault detection 

25 function. 

If the passwords are identical, as shown in the step 
1390, the remote requirement actual disk processing is executed 
and the flow ends. The remote requirement processing operation 
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may be performed by software alternatively when the processor 
is incorporated in the disk requirement processing section 110. 
The remote requirement actual disk processing is describe in 
reference to Fig. 14. 

A flow of the remote requirement actual disk 
processing is described referring to Fig. 14. First," as shown 
in the step 1410, the remote requirement processing section 121 
creates an actual disk processing requirement command 900 from 
the remote disk processing requirement command 700, and the 
flow proceeds to the step 1420. The actual disk ID 703 of the 
actual disk processing requirement command is identical with 
the actual disk ID 703 of the remote disk requirement command 
700, and the disk control command/data 403 of the actual disk 
processing requirement command is identical with the disk 
control command/data 403 of the remote disk requirement command 
700. Then, as shown in the step 1420, the remote requirement 
processing section 121 issues the actual disk processing 
requirement command 900 to the disk control mechanism sharing 
control section 115 , and the flow proceeds to the step 1430. 

As shown in the step 1430, the disk control mechanism 
sharing control section 115 serializes the actual disk 
processing command 900 issued from the remote requirement 
processing section 121 and the requirement control section 111, 
then issues it to the disk control mechanism 104, and the flow 
proceeds to the step 1440. The operation of the-disk control 
mechanism sharing control section 115 is described in reference 
to Fig. 15. As shown in the step 1440, the disk control 
mechanism 104 controls a disk (from 106-1 to 106-N) using the 
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actual disk processing requirement command 900, and the flow 
proceeds to the step 1450. 

As shown in the step 1450 , the disk control mechanism 
104 returns the actual disk processing status 1000 to the disk 
5 control mechanism sharing control section 115 as a return value 
of the control of the disk from 106-1 to 106-N by the actual 
disk processing requirement command 900, and the flow proceeds 
to the step 1460. Then, as shown in the step 1460, the disk 
control mechanism sharing section 115 returns the actual disk 
10 processing status 1000 to the remote requirement processing 
^ section 121, and the flow proceeds to the step 1470. 
w As shown in the step 1470, the remote requirement 

H processing section 121 creates a remote disk processing status 
}B 800 from the actual disk processing status 1000 based on the 
m structural definition information, and the flow proceeds to the 
Q step 1480. In the step 1480, the remote requirement processing 
H section 121 requests the transmission of the remote disk 
hi processing status 800 to the computer coupling mechanism 

adapter 123, and the flow proceeds to the step 1490. 
20 In the step 1490, the computer coupling mechanism 

adapter 123 transfers the remote disk processing status 800 to 
the remote requirement issue section 122 of the requirer 
computer through the computer coupling mechanism adapter 130, 
and the flow proceeds to the step 1492. Then, as shown in the 
25 step 1492, the remote requirement issue section. 122 retrieves 
the virtual disk ID 401 corresponding to the actual disk 
control computer ID 702 and actual disk ID 703 of the remote 
disk processing status 800 referring to the structural 
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definition information (refer to Table 1) and creates a disk 
processing status 500. The flow then proceeds to the step 
1495. In the step 1495, the remote requirement issue section 
122 returns the disk processing status 500 to the processor 
5 101, and the flow ends. The remote requirement actual disk 

processing operation may be performed by software alternatively 
when the processor is incorporated in the disk requirement 
processing section 110. 

Fig. 15 shows an embodiment of disk control mechanism 

10 sharing control section 115. The disk control mechanism 

sharing control section 115 comprises a remote requirement 

?*) processing section-corresponding-requirement holding section 

T~ 1510, requirement control section-corresponding-requirement 

holding section 1520, disk requirement serializing section 

=ir5 1530, and actual disk control section 1540. 

j£J The remote requirement processing 

1= section-corresponding-requirement holding section 1510 holds 

the actual disk requirement command 900 and actual disk 
processing status 1000 issued from the remote requirement 

20 processing section 121. The remote requirement processing 
section-corresponding-segment holding section 1510, for 
example, comprises logic such as TTL and CMOS . 

The requirement control 
section-corresponding-requirement holding section 1520 holds 

25 the actual disk requirement command 900 and actual disk 

processing status 1000 issued from the requirement control 
section 111. The requirement control section-corresponding- 
requirement holding section 1520, for example, comprises a 
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logic such as TTL and CMOS. 

The disk requirement serializing section 1530 
serializes the actual disk requirement command 900 issued from 
the remote requirement processing section 121 and the 
5 requirement control section 111, and provides it to the actual 
disk control section 1540. The disk requirement serializing 
section 153 0 , for example, comprises logic such as TTL and 
CMOS. Examples of the serialization of each requirement 
include round-robin scheduling in which requirements in the 

10 remote requirement processing section-corresponding-requirement 
holding section 1510 and a requirement in the requirement 

JH control section-corresponding-requirement holding section 1520 

! " are fetched alternately. 

The disk control section 1540 is a section for 

±5 issuing the actual disk requirement command 900 and receiving 

O the actual disk processing status 1000. Actual disk 

H requirement commands 900 are issued to the disk control 

mechanism 104 according to the order issued from the disk 
requirement serializing section 1530. Actual disk processing 

20 statuses 1000 are received according to the order issued from 
the disk control mechanism 104. The received actual disk 
processing status 1000 is transferred to the remote requirement 
processing section-corresponding-requirement holding section 
1510 and requirement control section-corresponding-requirement 

25 holding section 1520 through the disk requirement serializing 
section 1530. 

The actual disk processing status 1000 is returned 
from the remote requirement processing 
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section-corresponding-requirement holding position 1510 to the 
remote requirement processing section 121. The actual disk 
processing status 1000 is returned from the requirement control 
section-corresponding-requirement holding section 1520 to the 
5 requirement control section 111. The disk control mechanism 
sharing control section may be replaced by software 
alternatively when the processor is incorporated in the disk 
requirement processing section 110. 

A flow of the remote requirement refuse processing is 
10 illustrated in Fig. 16. First , as shown in the step 1610, the 
remote requirement processing section 121 creates a remote disk 
processing status 800 from the status to the access right error 
! b and password error and remote disk processing requirement 

command 700, and the flow proceeds to the step 1620. The 
fS5 remote disk processing requirement command 700 and the remote 
Q disk processing status 800 are identical except for the disk 

M control command/data 403 and disk status/data 503. 

As shown in step 1620, the remote requirement 
processing section 121 requests the computer coupling mechanism 
20 adapter control section 123 to transmit the remote disk 

processing status 800, and the flow proceeds to the step 163 0. 
Then, as shown in step 1630, the computer coupling mechanism 
adapter 12 3 transfers the remote disk processing status 800 to 
the remote requirement issue section 122 of the requirer 
25 computer, and the flow proceeds to the step 1640. 

In step 1640, the remote requirement issue section 
122 creates a disk processing status 500 from the remote disk 
processing status 800 by retrieving the virtual disk ID 401 
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corresponding to the actual disk control computer ID 702 and 
actual disk ID 703 of the remote disk processing status 800 and 
referring to the structural definition information (refer to 
Table 1. The flow then proceeds to the step 1650. 

In step 1650, the remote requirement issue section 
122 returns the disk processing status 500 to the processor 
101, and the flow ends. The remote requirement refusing 
operation may be performed by software alternatively when the 
processor is incorporated in the disk requirement processing 
section 110. 

As described hereinbefore, according to the present 
invention, processing requirement between the bus to which hard 
disks to be shared and the attachment for remote access are 
transferred as required, thereby, an access to the attachment 
is operated only when it is necessary, and the processor in 
which a requirement arises controls directly the hard disk. 
Thus, a loosely-coupled computer system having high performance 
shared disks can be structured. 

While the present invention has been described in 
detail and pictorially in the accompanying drawings it is not 
limited to such details since many changes and modifications 
recognizable to those of ordinary skill in the art may be made 
to the invention without departing from the spirit and the 
scope thereof. 



27 



